Scroll to navigation

PS(1) Manual del Programador de Linux PS(1)

NOMBRE

ps - informa del estado de los procesos

SINOPSIS

ps [-] [lujsvmaxScewhrnu] [txx] [O[+|-]k1[[+|-]k2...]] [pids]

también existen tres opciones largas:

--sortX[+|-]key[,[+|-]key[,...]]

--help

--version

Se están desarrollando más opciones largas...

DESCRIPCIÓN

ps muestra una instantánea de los procesos actuales. Si quiere una actualización contínua, use top. Esta página de manual documenta (o por lo menos intenta documentar) la versión de ps basada en /proc.

OPCIONES DE LA LÍNEA DE COMANDOS

Las opciones de la línea de comandos para esta versión de ps proceden de la versión BSD de ps, no de la versión System V.

Es recomendable que los argumentos de la línea de comandos no estén precedidos por un carácter `-', porque en un futuro, el `-' se utilizará para indicar argumentos del estándar Unix98, mientras que sin `-' indicará el modo actual ``BSD extendido''.

Por ahora, ps mostrará una advertencia (warning) si usa un `-' para una opción corta, pero aún así, todavía funcionará. Si tiene scripts shell que utilizan los argumentos de ps tipo BSD, preste atención a las advertencias y soluciónelas, o sus scripts dejarán de funcionar de forma correcta en un futuro. Si quiere deshabilitar estas advertencias, establezca la variable de entorno I_WANT_A_BROKEN_PS.

Existen además algunas ``opciones largas'' estilo GNU; véase más abajo.

formato largo
formato usuario: muestra el usuario y la hora de inicio
formato trabajo (jobs): pgid sid
formato señal (signal)
formato vm
muestra información de memoria (combínese con p para obtener el número de páginas).
formato "forest" ("bosque") de familias en forma de árbol
muestra también los procesos de otros usuarios
muestra procesos que no están controlados por ninguna terminal
añade tiempo de CPU y fallos de página de los hijos
nombre del comando obtenido de task_struct
muestra ambiente (environment) después del nombre del comando y ` + '
Salida ancha (wide): no se truncan las líneas de comando para que quepan en una línea. Para ser exactos, cada w que se especifica añadirá una posible línea a la salida. Si el espacio no se necesita, no se usa. Puede usar hasta 100 w's.
sin cabecera (header)
sólo procesos que se están ejecutando
salida numérica para USER y WCHAN.
sólo procesos controlados por la tty xx; para xx debe usar bien el nombre de un dispositivo bajo "/dev" o bien ese nombre sin las letras tty o cu que lo preceden. Esta es la operación inversa que ps utiliza para imprimir el nombre abreviado de tty en el campo TT, por ejemplo, ps -t1.
Ordena la lista de procesos de acuerdo con el ordenamiento multi-nivel especificado por la secuencia de claves ordenación de CLAVES DE ORDENACIÓN, k1, k2, Existen especificaciones de ordenación por defecto para cada uno de los formatos de ps. Éstas pueden ser anuladas por una ordenación especificada por el usuario. El `+' es opcional, meramente para reiterar la dirección por defecto de una clave. `-' invierte la dirección sólo de la clave que precede. Como con t y pids, la opción O debe ser la última opción en un argumento, aunque las especificaciones en argumentos posteriores son concatenadas.
Lista sólo los procesos especificados; están delimitados por comas. La lista se debe dar inmediatamente después de la última opción en un argumento simple, sin intervención de espacios, por ejemplo ps -j1,4,5. Las listas especificadas en los argumentos siguientes son concatenadas, por ejemplo ps -l 1,2 3,4 5 6 listará todos los procesos del 1 al 6 en formato largo. Los pids se listan incluso si contradicen a las opciones 'a' y 'x'

OPCIONES DE LA LÍNEA DE COMANDOS LARGAS

Estas opciones están precedidas por un doble guión.

Selecciona una clave de varias letras de la sección CLAVES DE ORDENACIÓN. X puede ser cualquier carácter de separación. GNU prefiere `='. El `+' es realmente opcional, ya que la dirección por defecto es creciente en orden numérico o lexicográfico. Por ejemplo: ps -jax --sort=uid,-ppid,+pid
Muestra un mensaje de ayuda que resume el uso y da una lista de claves de ordenación soportadas. Esa lista puede estar más actualizada que la de esta página del manual.
Muestra la versión y la procedencia de este programa.

CLAVES DE ORDENACIÓN

Nótese que los valores utilizados en la ordenación son valores internos que ps utiliza y no los valores `transformados' (`cooked') que aparecen en alguno de los campos de la salida. Si alguien, voluntariamente, quiere escribir alguna función especial de comparación para los valores transformados, ... ;-)

CORTA LARGA DESCRIPCIÓN

s size memoria usada en kilobytes
t tty el tty que usa el proceso

DESCRIPCIÓN DE LOS CAMPOS

Este es el campo contador de la estructura de la tarea. Es el tiempo en HZ de la posible rodaja de tiempo del proceso.
Valor nice estándar de Unix; un número positivo significa menos tiempo de cpu.
Tamaño virtual de la imagen; Tamaño de text+data+stack.
Tamaño de la parte residente; kilobytes del programa en memoria.
Nombre de la función del kernel que el proceso estaba ejecutando cuando pasó a estar durmiendo, con el `sys_' quitado del nombre de la función. Si no existe el fichero /etc/psdatabase , se muestra sólo un número hexadecimal.
Información acerca del estado del proceso. El primer campo es R para preparado para ejecución (runnable), S para durmiendo (sleeping), D para indicar letargo ininterrumpible (uninterruptible sleep), T para parado o trazado (traced), o Z para un proceso zombie. El segundo campo contiene W si el proceso no tiene páginas residentes. El tercer campo es N si el proceso tiene un número nice positivo (campo NI ).
Tty asociada.
Número de fallos de página mayores (fallos de página que causan lectura de páginas desde el disco, incluyendo las páginas leídas desde el buffer de caché).
Tamaño del código residente.
Kilobytes (o páginas si usamos -p ) en el dispositivo de intercambio (swap).
Memoria compartida.

ACTUALIZANDO

Este ps (basado en proc) lee los ficheros en el sistema de ficheros proc , montado en /proc. No necesita un kmem con suid ni privilegios para funcionar. No dé a este ps ningún permiso especial.

Necesitará actualizar el fichero /etc/psdatabase ejecutando /usr/sbin/psupdate para obtener una información comprensible del campo WCHAN. Debería hacer esto cada vez que compile un nuevo kernel. Debería también ejecutar 'ps' como root una vez y cada vez que los dispositivos tty en el directorio "/dev" cambien.

Como procps-1.00, ps/top leen System.map directamente si existe. El camino de búsqueda para la resolución de dirección a símbolo del kernel (address-to-symbol) es:


$PS_SYSTEM_MAP
/boot/System.map-`uname -r`
/boot/System.map
/lib/modules/`uname -r`/System.map
/etc/psdatabase
/boot/psdatabase-`uname -r`
/boot/psdatabase,
/lib/modules/`uname -r`/psdatabase

NOTAS

El miembro used_math de task_struct no se muestra, ya que crt0.s comprueba si existe emulación de coprocesador matemático. Esto hace que el flag math esté activado para todos los procesos, por lo que es inútil.

Los programas intercambiados a disco se mostrarán sin los argumentos de la línea de comando, y a no ser que se de la opción c , entre paréntesis.

%CPU muestra el porcentaje tiempo de cpu/tiempo real. No llegará al 100% a no ser que tengas suerte. Es el tiempo utilizado dividido por el tiempo que el proceso se ha estado ejecutando.

Los campos SIZE y RSS no cuentan las tablas de páginas y la task_struct del proceso; esto supone por lo menos 12k de memoria que siempre está residente. SIZE es el tamaño virtual del proceso (código+datos+pila).

Para conseguir la correspondencia entre número y nombre de dispositivo, ps mantiene un fichero llamado "/etc/psdevtab" (actualizado cada vez que "/dev" se actualiza y los permisos permitan la actualización). Si los permisos no lo permiten, cada invocación de ps requiere que se ejecute un stat(2) a cada fichero en el directorio "/dev". Si las entradas en "/dev" cambian a menudo en su sistema, debería ejecutar ps como root a menudo. Puede que añada un fichero accesorio bajo $HOME si se demanda por los usuarios.

AUTOR

ps fue escrito por primera vez por Branko Lankester <lankeste@fwi.uva.nl>. Michael K. Johnson <johnsonm@redhat.com> lo modificó de forma significativa para que utilizara el sistema de ficheros proc, cambiando algunas cosas en el proceso. Michael Shields <mjshield@nyx.cs.du.edu> añadió la posibilidad de dar listas de pids. Charles Blake <cblake@bbn.com> añadió ordenación multi-nivel, la librería estilo dirent, la base de datos de correspondencia de nombre de dispositivo a número, la búsqueda binaria aproximada en System.map, y mejoró el código y la documentación. David Mossberger-Tang escribió el soporte genérico BFD para psupdate. Michael K. Johnson <johnsonm@redhat.com> es el encargado del mantenimiento actualmente.

Por favor, envíe informes de los fallos a <procps-bugs@redhat.com>

3 Septiembre 1997 Cohesive Systems